

11-14-00

A



11/13/00



EPSTEIN, EDELL, SHAPIRO & FINNAN, LLC  
1901 Research Boulevard, Suite 400  
Rockville, Maryland 20850-3164  
(301) 424-3640

BOX PATENT APPLICATION  
ASSISTANT COMMISSIONER FOR PATENTS  
Washington, D. C. 20231

Sir:

Docket No.: 0918.0044C

Transmitted herewith for filing is a patent application of:

**Inventor (1):** James M. Clark

**Address:** 87 Woodland Avenue  
Verona, NJ 07044

**For:** Method and Apparatus for Generating and Transmitting a Stationary Dither Code

Enclosed are:

New Patent Application including:  
Twenty-two (22) Pages of Specification;  
Thirteen (13) Sheets of Formal Drawings; and  
Certification under 37 CFR 1.10

The filing fee has been calculated as shown below:

|                    |    |              |                             |
|--------------------|----|--------------|-----------------------------|
|                    |    |              | BASIC FILING FEE: \$ 710.00 |
|                    |    |              | LATE FILING FEE: \$ 130.00  |
| TOTAL CLAIMS       | 25 | - 20 =       | 5                           |
| INDEPENDENT CLAIMS | 4  | - 3 =        | 1                           |
|                    |    | Extra x 18 = | \$ 90.00                    |
|                    |    | Extra x 80 = | \$ 80.00                    |
|                    |    | TOTAL        | \$1,010.00                  |

All correspondence regarding this application should be directed to EPSTEIN, EDELL,  
SHAPIRO & FINNAN, LLC at the above address.

Respectfully submitted,

J. Warren Lytle, Jr.  
Registration No. 39,283

Express Mail No.: EK409285120US  
Express Mailed on: 11/13/2000

IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

In re the PATENT application of

James M. Clark

Atty. Docket No.: 0918.0044C

Serial No.: Not Yet Assigned

Filed: Herewith

For: Method and Apparatus for Generating and Transmitting a Stationary Dither Code

CERTIFICATION UNDER 37 CFR 1.10

EK409285120US

11/13/2000

“Express Mail” mailing number

Date of Deposit

I hereby certify that a transmittal (1 page), specifications (22 pages) and formal drawings (13 sheets) for the above-identified application are being deposited with the United States Postal Service “Express Mail Post Office to Addressee” service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Washington, D.C. 20231.

Lydia H. Cochran

(Typed or Printed Name of  
person mailing application)



(Signature of person mailing  
Application)

1           METHOD AND APPARATUS FOR GENERATING AND TRANSMITTING A  
2           STATIONARY DITHER CODE  
3

4           CROSS REFERENCE TO RELATED APPLICATION

5           This application claims priority from U.S. Provisional Patent Application  
6           Serial Nos. 60/164,952, entitled "Optimal Stationary Dither Code," and 60/164,946,  
7           entitled "Stationary Dither Code Detection," both filed November 12, 1999. The  
8           disclosures of these provisional patent applications are incorporated herein by  
9           reference in their entirety.

10           ~~11~~           BACKGROUND OF THE INVENTION

11           ~~12~~           Field of the Invention

13           The present invention relates to data communication and timing systems and,  
14           more particularly, to data communication and timing systems using codes with coding  
15           boundaries that vary according to a dithering pattern.

16           ~~17~~           Description of the Related Art

18           Pseudonoise (PN) codes, also known as pseudorandom codes, have good  
19           autocorrelation properties and are ideal for measuring the time-of-arrival of a signal,  
20           and hence, for use in ranging applications. A high coding gain is achieved when a  
21           receiver correlates the code, such as a PN code, for a long time. Accordingly, long PN  
22           codes have been used to provide high coding gain.

23           An example of using a long PN code is in the Global Positioning System  
24           (GPS). GPS is a satellite-based navigation system in which each satellite in the GPS  
25           constellation transmits a unique precision (P) code. Each P code is a very long PN  
26           code that has a period of one week, and hence, repeats only once per week. The P  
27           code provides for a high gain correlation signal that allows a receiver to acquire  
28           precise timing information, and hence, precise ranging information between the  
29           receiver and satellite. To acquire the P code signal a receiver must determine the  
30           phase of the received P code. However, because the P code is so long it is difficult for

a receiver to determine its phase. If a receiver includes a very accurate clock, such as an atomic clock, it might stay synchronized with the transmitter's clock and could therefore generate a local reference P code that is nearly in-phase with the received P code. But this would require an expensive, complex and unwieldy receiver. Even with a very accurate and stable clock frequency, there is the problem of initially setting the correct time of day. This requires testing all of the code phases that span the range of the time uncertainty. Theoretically a receiver could include enough correlators to test each phase of the P code simultaneously to detect its phase, but in practice that a solution would not be feasible because of the extremely large number of correlators required due to the length of the P code. A receiver also, theoretically, uses a practical number of correlators and test the possible phases of the P code sequentially. However, this would take a long time due to the length of the P code.

The GPS system uses another technique to acquire the P code. It uses a second signal, known as the course acquisition (C/A) signal, to determine initial timing information, then uses that timing information to assist in detecting the phase of the P code. The C/A signal is a much shorter code of 1023 symbols and repeats approximately every millisecond. Accordingly, the C/A code can be detected quickly, either by using a bank of correlators to test each possible phase of the code, or by testing the phases in sequence. However, the C/A code can provide timing only within a one millisecond interval (one interval cannot be distinguished from another), and thus, by itself, cannot resolve all of the time uncertainty (typically a few seconds). But once a GPS receiver acquires the C/A signal, it can determine enough timing information to limit the P code search to specific phases of the P code to speed its acquisition of the P code. However, using one code to help acquire a longer code, such as in the GPS system, requires that the transmitter generate and transmit two signals and that a receiver be able to receive and detect both signals.

Accordingly, there is a need to generate and transmit a long code with good autocorrelation characteristics that can be acquired quickly by using a feasible number of correlators and without requiring another signal that provides timing information.

A conventional spread-spectrum communications system, such as the GPS system, is shown in Fig. 1. The system of Fig. 1 includes a transmitter 1 and a

1 receiver 9. The transmitter includes a PN code generator 2 that is driven by a timing  
2 counter 3 and both are run based on a clock oscillator 4. The PN code generated by  
3 generator 2 is modulated with a carrier signal via modulator 5 which is driven by  
4 carrier oscillator 6. Optionally, data can be superimposed onto the code and carrier by  
5 using a modulo 2 adder 7. The transmitter 1 transmits the modulated carrier via  
6 antenna 8 to a receiver 9.

7 Receiver 9 receives the transmitted signal via an antenna 10 that provides the  
8 received signal to a demodulator 11. The demodulator 11 is driven by a carrier  
9 oscillator 12, and produces two signals out-of-phase by 90°. Those signals are  
10 designated as in-phase (I) and quadrature(Q) signals. These two out-of-phase signals  
11 are provided to a group of parallel correlators 13. The parallel correlators can include  
12 as many, and even more, correlators as the number of phases of the code to be tested.  
13 For example, if the code length is 1023 symbols, or chips, the parallel correlators 13  
14 can consist of 1023 correlators, one correlator for each possible phase of the code.  
15 Multiple banks of the parallel correlators 13 can be used to correlate different signals,  
16 such as in this case where one bank correlates the I-signals and another bank  
17 correlates the Q-signals. The parallel correlators 13 are also provided with PN  
18 reference codes that correspond to the PN codes generated in the transmitter. PN code  
19 generator 14 generates the reference codes. The reference codes can be delayed to  
20 correspond to the various phases to be tested. Alternatively, the input signals, here the  
21 I and Q signals, can be delayed with various delays and correlated with a single PN  
22 code to test the different phases. The PN code generator 14 is driven by a local clock  
23 oscillator 15 and timing counters 16 which can effect the different timings for the PN  
24 reference codes. The local clock oscillator also drives timing counters 16.

25 Many different types of PN code generators can be used in spread-spectrum  
26 systems such as that shown in Fig. 1. A small scale example of one such conventional  
27 PN code generator is shown in detail in Figure 2. The PN code generator of Fig. 2  
28 includes a shift register 20 and a modulo-2 adder 21. In this example, the shift  
29 register is three bits long, although longer lengths are usually used. The three flip-  
30 flops of shift register 20 are synchronously driven by a clock signal. Modulo-2 adder  
31 adds the first and third bits of the shift register, and inserts the result into the first

1 position of register 20 while all bits are shifted to the right by one position. Starting  
2 with any pattern other than all zeros in the register, repeating this operation once for  
3 each clock pulse produces an output pattern, shown in Fig. 3B, that repeats every  
4 seven bits. In this manner, a maximal-length PN sequence is produced.

5 A sequence of PN codes is shown in Figs. 3A and B. The sequence in Fig. 3A  
6 shows the symbol positions in a 7-symbol PN code, with the symbol positions labeled  
7 0 through 6. Fig. 3B shows the symbol values, where the symbols are bits, and the  
8 code is "0010111." Here, the code repeats regularly without variation in code length  
9 or phase, and hence, a receiver cannot discriminate one instance of the code from  
10 another.

11 These conventional transmitters, receivers and code generators suffer from the  
12 problems described above and are unable to generate a long code that can be received  
13 quickly and inexpensively, without the aid of a second timing signal. Accordingly,  
14 there is also a need for a generator and transmitter that can produce a long code with  
15 good autocorrelation properties, yet can be acquired quickly and inexpensively  
16 without the need for first detecting a second timing signal.  
17

18 SUMMARY OF THE INVENTION

19 Therefore, in light of the above, and for other reasons that become apparent  
20 when the invention is fully described, an object of the present invention is to generate  
21 a long code from a sequence of shorter codes, where the shorter codes are dithered  
22 versions of the same short code. When the dither pattern is fixed, generally so that the  
23 receiver can know it beforehand, the long code constructed with that dither pattern is  
24 referred to here as a stationary dither code.

25 Another object of the present invention is to generate an optimal stationary  
26 dither code.

27 Yet another object of the present invention is to generate a long code with  
28 optimum autocorrelation properties.

29 A further object of the present invention is to generate a long code with good  
30 autocorrelation properties from a short code also with good autocorrelation properties.

1 Yet a further object of the present invention is to use a single pseudonoise  
2 generator to generate a long code with the easier detection characteristics typical of a  
3 short code.

4 A still further object of the present invention is to generate a long code with a  
5 predetermined dither pattern.

6 Yet another object of the present invention is to provide an apparatus that  
7 achieves one or more of the above objects.

8 The aforesaid objects are achieved individually and in combination, and it is  
9 not intended that the present invention be construed as requiring two or more of the  
10 objects to be combined unless expressly required by the claims attached hereto.

11 In accordance with one aspect of the present invention there is provided a  
12 method of generating a dither code, that includes a) generating a first short code by  
13 dithering a reference code according to a dither pattern; b) generating a second short  
14 code by dithering the reference code according to the dither pattern, wherein the code  
15 phases of the first and second short codes are different from each other; c) repeating a)  
16 and b) a predetermined number of times; and d) outputting in sequence the short codes  
17 generated in a) through c) as the dither code.

18 According to another aspect of the invention there is provided a method of  
19 constructing (designing) a composite code from M instances of a reference code,  
20 where M is an integer. The method is an iterative method; that is, when the composite  
21 code is partly constructed, having so far N-1 instances of the reference code, certain  
22 operations are performed to add another instance of the reference code to the  
23 construction. These operations include:

24 a) referring to the last, that is, the (N-1)th, code generated from the reference  
25 code, the (N-1)th code having an (N-1)th phase position, where N is an integer less  
26 than M;

27 b) selecting the next, that is, the Nth, code generated from the reference code,  
28 the Nth code having an Nth phase position, avoiding disallowed code points that were  
29 previously determined, and determining the phase difference V between the phase of  
30 the (N-1)th code and the phase of the Nth code; and

1                   c) adding the phase difference V to the phase of the (N-1)th code and  
2                   likewise, codes generated prior to the (N-1)th code, to determine disallowed code  
3                   points.

4                   According to yet another aspect of the invention there is provided an apparatus  
5                   for generating a composite code, such as one designed by the above method. The  
6                   apparatus includes a clock oscillator outputting a clock signal; a controller coupled to  
7                   the clock oscillator, counting in response to the clock signal, and generating a control  
8                   signal based on the count and indicating a dither amount; and a code generator  
9                   coupled to the controller and generating a code dithered in response to the control  
10                  signal, wherein the controller generates the control signal to indicate an amount of  
11                  dither for the generated code so the phase of the generated code differs as specified, as  
12                  designed, or as desired from the preceding code generated by the code generator.

13                  According to still another aspect of the invention there is provided a  
14                  transmission signal, comprising M codes each having a phase dithered with respect to  
15                  a reference code, wherein the phases of the M codes are dithered according to a dither  
16                  pattern. The phases of the M codes can be dithered by varying the lengths of the M  
17                  codes according to the dither pattern, or dithered by rotating the phase of the reference  
18                  code according to the dither pattern, and such that the transmission signal has an  
19                  optimal autocorrelation characteristic.

20                  The above and still further objects, features and advantages of the present  
21                  invention will become apparent upon consideration of the following descriptions and  
22                  descriptive figures of specific embodiments thereof. While these descriptions go into  
23                  specific details of the invention, it should be understood that variations may and do  
24                  exist and would be apparent to those skilled in the art based on the descriptions  
25                  herein.

26  
27                    BRIEF DESCRIPTION OF THE DRAWINGS

28                  Fig. 1 is a block diagram of a conventional spread-spectrum communication  
29                  system.

30                  Fig. 2 shows a conventional pseudonoise generator.

31                  Fig. 3A shows bit positions of a seven-bit code.

1 Fig. 3B shows values of the seven-bit code shown in Fig. 3A.

2 Fig. 4A shows an example boundary dither code.

3 Fig. 4B shows an example rotation dither code.

4 Fig. 4C shows alignments of a reference code with the boundary dither and  
5 rotation dither codes shown in Figs. 4A and B that a receiver might use to detect either  
6 of the dither codes shown in Figs. 4A and B.

7 Fig. 5 is a dither pattern graph showing a dither code's code and phase  
8 positions.

9 Fig. 6 is a block diagram of a transmitter according to one embodiment of the  
10 invention.

11 Fig. 7 is a flowchart showing operations for generating a stationary dither code  
12 according to the invention.

13 Fig. 8 is a flowchart showing operations for generating a boundary and rotation  
14 stationary dither codes according to the invention.

15 Fig. 9A shows matching a boundary dithered code and a reference code.

16 Fig. 9B shows matching a rotation dithered code and a reference code.

17 Fig. 10A is a flowchart showing operations for generating an optimal  
18 stationary dither code according to the invention.

19 Fig. 10B shows a table for storing selected points, vectors and disallowed  
20 points generated during the process illustrated in Fig. 10A.

21 Figs. 11A-C are dither pattern graphs illustrating various stages involved in  
22 generating an optimal stationary dither code according to the invention.

23 Fig. 12A is a dither pattern graph of an example optimum long dither code  
24 generated from 81 short pseudonoise codes.

25 Fig. 12B is a dither pattern graph showing ten examples of optimum dither  
26 codes, each generated from 50 short pseudonoise codes.

1                   DESCRIPTION OF THE PREFERRED EMBODIMENTS

2                   Preferred embodiments according to the present invention are described below  
3                   with reference to the above drawings, in which like reference numerals designate like  
4                   components.

5                   *Overview*

6                   According to the present invention, a long code can be generated by using a  
7                   reference code with good autocorrelation properties, such that a receiver can detect the  
8                   long code without having to correlate each phase of the long code concurrently with  
9                   parallel correlators, or over time over the entire period of the long code. Rather, the  
10                  code can be quickly detected by using a reasonable number of correlators, similar to  
11                  the number of correlators that would be used to detect the reference code. The long  
12                  code is generated by repeating the reference code with a fixed pattern of phase  
13                  variations called dither. Various types of dither can be used, as described below in  
14                  detail. Also, certain methods described here generate optimal dither patterns where  
15                  the autocorrelation of the long code is ideal if the autocorrelation of the short code is  
16                  ideal.

17                  A co-pending patent application, entitled “Method and Apparatus for  
18                  Detecting a Stationary Dither Code,” relates to detecting stationary dither codes, and  
19                  is incorporated herein by reference.

20                  *Dither Types*

21                  A dither code can be generated from a predetermined code, by changing  
22                  certain aspects of that predetermined code. There are many PN codes that can be  
23                  used, such as m-sequences produced by a generator like that shown in Fig. 2. For  
24                  example, a reference code N chips, or bits, long with good autocorrelation properties  
25                  is selected. A code generator generates a long code according to the invention, by  
26                  repeating the reference code M times. However, so that a receiver can distinguish one  
27                  part of the long code from another, the generator varies the timing, or dithers, the  
28                  repetitions of the reference code. The varied timing repetitions of the reference code  
29                  are referred to here as short codes. The original undithered code is referred to here as  
30                  the reference code, because a receiver typically will generate the reference code and  
31                  use it as a reference to detect the dithered short codes.

1           One kind of dither is a boundary dither that is created by varying the lengths of  
2       the short codes by small amounts. All of the short codes start the same way, but a  
3       generator adds or deletes bits at the ends of the codes in order to vary the length of the  
4       reference code. The boundaries between the short codes are thus not equally-spaced,  
5       but are varied by the dither pattern. The length of the long code is nominally  $M \cdot N$   
6       chips, but perhaps not exactly, because of the length variations due to the boundary  
7       dither.

8           Another kind of dither is rotation dither, performed by rotating the short codes,  
9       yet keeping the code length constant. That is, the short codes start in varying states, or  
10      at varying phases of the code, and each rotation dithered short code includes the entire  
11      reference code. The boundaries between the rotation dithered short codes are equally-  
12      spaced since the code lengths are the same, but there remains one feature in common  
13      with the boundary dither. Namely, if a dithered code is compared with an undithered  
14      code, the code phase of the short codes will appear to shift back and forth in some  
15      pattern referred to here as the dither pattern. The length of the long code is exactly  
16       $M \cdot N$  symbols, or chips, in the case of rotation dither.

17           The dither patterns, also called dither codes, considered here are fixed, and  
18       thus they are called stationary dither codes.

19           Figs. 4A-C illustrate the two types of dither with a small-scale example, in  
20      which the 7-bit code of Fig. 3 is repeated four times. Dithering the 7-bit reference  
21      code by the boundary dither method varies the lengths of the codes. The codes  
22      marked in Fig. 4A as (-1) are one bit shorter, and those marked (+1) are one bit longer  
23      than the reference code.

24           Dithering the 7-bit reference code by the rotation dither method shifts the  
25      codes. The codes marked in Fig. 4B as (-1) are rotated one bit to the left, those  
26      marked (+1) are rotated one bit to the right, and those marked (0) are not rotated.

27           For either type of dither, a receiver can generate a reference code (an  
28      unmodified 7-bit code) and find phase shifts of the reference code that are aligned  
29      with the received codes, as illustrated in Fig. 4C. The aligned reference codes and  
30      received codes will match almost entirely, except for a few bits at the ends of the

1 codes, and thus, will produce a strong correlation. Accordingly, a long code with a  
2 long period can be generated using only a single, short reference code.

3 *Two-Dimensional Dither Representation*

4 A dither code can be portrayed as a two-dimensional pattern, as illustrated in  
5 Fig. 5. In Fig. 5 the horizontal “x” coordinate designates each of the short codes  
6 corresponding to the repetitions of the dithered reference code. The vertical “y”  
7 coordinate designates the phase shift of each code from its undithered position. The  
8 phase changes (also called phase jumps) correspond to the code length variations of  
9 the boundary dither; and the phase positions correspond to the code shift variations of  
10 the rotation dither, and also correspond to the alignment positions of the receiver's  
11 reference code.

12 Fig. 5 shows a two-dimensional dither pattern representing the dither codes  
13 shown in Figs. 4A-C . The code length variations of the boundary dither code, shown  
14 in Fig. 4A, correspond to phase changes shown in Fig. 5. For example, the difference  
15 in code length between the reference code and the first short code shown in Fig. 4A is  
16 -1 because the first short code is one bit shorter than the reference code shown in Fig.  
17 4C. This corresponds to a phase change of “-1” going from phase position “0” for the  
18 reference code to phase position “-1” for the first short code. Fig. 4A shows this  
19 phase change over the first short code of the boundary dither code. The phase change  
20 can be considered a phase vector going from (0, 0) to (-1, 0). The second short code  
21 of the boundary dither code shown in Fig. 4A has a phase change of +1 because the  
22 phase vector goes from (1, -1) to (2, 0). Likewise, the phase vector of the third short  
23 code is +1, as is the phase vector for the fourth short code shown in Fig. 4A.

24 The code shift variations of the rotation dither code, shown in Fig. 4B,  
25 correspond to the phase changes shown in Fig. 5. For example, the first short code of  
26 the rotation dither code shown in Fig. 4B has a phase change of “0” because the short  
27 code is identical to the reference code. The second short code of the rotation dither  
28 code is circularly shifted one position to the left, and hence, has a phase change of “-  
29 1” as shown in Fig. 4B, and is represented by the point at (1, -1). This is shown in  
30 Fig. 5 by the phase position changing from (0,0) to (1, -1). The third short code of  
31 Fig. 4B has the same phase as the reference code, and hence, a phase change of

1 “0,” and is shown in Fig. 5 as the point (2, 0). The fourth short code of Fig. 4B is  
2 circularly shifted one position to the right, and hence, has a phase change of “+1,” and  
3 is shown in Fig. 5 as the point (3, 1).

4 The alignment positions of the receiver’s reference code correspond to the  
5 phase positions in Fig. 5.

6 Thus, a dithered long code can be represented by a two-dimensional dither  
7 pattern graph such as the graph shown in Fig. 5.

8 *Stationary Dither Code Generator/Transmitter*

9 A stationary dither code generator and transmitter, according to one  
10 embodiment of the invention is shown in Fig. 6. The transmitter 1 includes like  
11 components of the conventional transmitter shown in Fig. 2, except that in place of  
12 timing counters 3 the transmitter includes a counter/controller unit 60. The  
13 counter/controller 60 controls the PN code generator 2 to either vary the length of the  
14 generated PN code or to alter the phase of the generated PN code by starting the  
15 sequence at various phases of the code. The result is that a stationary dither code,  
16 such as either a boundary or rotation dithered code, is output from PN code generator  
17 2 that is ultimately transmitted.

18 A method of generating a stationary dithered code is shown in Fig. 7. The  
19 method starts at operation 70, and in operation 71 the PN code generator 2 is  
20 initialized and dither parameters, such as the type and amount of dither, and dither  
21 pattern, are initialized. Also, variables t and c are set to zero, where t is the time  
22 position (in chips) within a code, and c is a number identifying a short code. In  
23 operation 72 if a clock signal occurs the process flows to operation 74, but if it does  
24 not occur the process waits in operation 73 for a clock signal. In operation 74 the  
25 counter/controller 60 controls the PN code generator 2 to generate a code symbol  
26 according to the type of dither selected in operation 71. Operation 74 is shown in  
27 greater detail in Fig. 8. If, according to the type of dither and dither pattern in use, the  
28 next symbol or chip of the current code is to be generated, the process flows to  
29 operation 75 where the PN code generator 2 is modulo incremented to generate a next  
30 chip “p”. After operation 75 the process flows to operation 72 to await the next clock  
31 signal. If, however, in operation 74 it is determined that the current code is

1 completed, the process flows to operation 76 where the PN code generator 2 is reset to  
2 begin the next code. After operation 76 the process flows to operation 72 to await the  
3 next clock signal.

4 Operation 74 is shown in more detail in Fig. 8, and begins at the point denoted  
5 “A” in which the process flows from operation 72 to operation 80. Here, the nominal  
6 length of a short code is denoted “L”, the current length of the boundary-dithered code  
7 is “q”, the mth chip of the reference code is  $p[m]$ , and the dither phase for short code c  
8 is denoted  $d[c]$ . In operation 80 the type of dither is detected based on the initialized  
9 dither parameters.

10 If the system uses boundary dither the process flows to operation 81 where the  
11 dither length “q” is calculated for the present short code “c”. The length q of code c is  
12 calculated based on the boundary dither pattern in use. The nominal length L is varied  
13 by the difference in the dither phase  $d[c]$  for code c and the dither phase  $d[c+1]$  for the  
14 next code, thus,  $q=L+d[c+1]-d[c]$ . The process then flows to operation 82, which  
15 determines if the chip time t is still within the current code interval. If so, the next  
16 chip will be  $p[t]$ , that is, chip t of the reference code, as indicated in operation 83, and  
17 the process flows in operation 84 back to the point designated “C” shown in Fig. 7.  
18 However, if t is not less than q, then the process flows to operation 85, where flow  
19 returns back to the point designated “B” shown in Fig. 7.

20 If rotation dither is in use, then the process flows to operation 86, which  
21 determines if chip time t corresponds to the end of the code. This is similar to  
22 operation 82, but here the code length is constant (equals L). If the end of the code  
23 has not yet been reached, then the next chip is to be output. As indicated in operation  
24 87, the next chip will be  $p[t+d[c]]$  modulo L; that is, the chip position is shifted by the  
25 amount of the dither phase  $d[c]$ . Since the shift is a rotation, and bits can “wrap  
26 around”, the modulo operation is needed. The process then flows to operation 88  
27 which returns to the point designated “C” in Fig. 7 to output the next chip. If  
28 however, the end of the rotated code is reached, then the process flows to operation 89  
29 which returns the flow to the point designated “B” shown in Fig. 7.

## *An Optimal Stationary Code*

The autocorrelation of a long code will be optimum if the vector difference between any two points in the two-dimensional pattern for a dithered code is never repeated. This assures that no shifted alignment of two copies of the long code will match for any more than one short code.

This property is not satisfied by the small example code shown in Figs. 4A-C and by the dither pattern shown in Fig. 5, because the vector difference between code positions 1 and 2 (+1) is the same as between code positions 2 and 3 (+1). As a result, there is an alignment for which two short codes match, except for a few bits at the ends of the codes, as shown in Figs. 9A and 9B. For the boundary dither code example, the second and third short codes match, except for a few bits at the end of the code, the third and fourth short codes of that code as shown in Fig. 9A. Similarly, the second and third short codes of the rotation dither code match, except for a few bits at the end of the code, the third and fourth short codes of that code as shown in Fig. 9B. Accordingly, the boundary dither and rotation dither codes shown in Figs. 4A and 4B are non-optimal stationary dither codes.

Optimal Stationary Code Generation Method

An optimal stationary code has an optimum autocorrelation, and is produced by ensuring that the vector difference between any two points in the two-dimensional pattern for a dithered code is never repeated while creating the code one phase jump at a time. Applying this method determines the phase jumps that are not allowed. In generating an optimal stationary code, the phase jumps are chosen from the allowable phase jumps either by preference rules and/or by random choices.

A method for producing an optimal stationary code according to the invention is illustrated here in which the smallest allowable phase jump is given preference. However, the invention is not limited to giving preference to the smallest allowable phase jumps, and other phase jumps and preferences can be used.

In describing various methods for generating an optimal stationary code, the following terminology is used in connection with dither pattern diagrams, such as the diagram shown in Fig. 5. "Point x, y" refers to code position x and phase position y, where position x is on the horizontal axis and the position y is on the vertical axis of

1 the dither pattern graph such as that shown in Fig. 5. “Adding a vector to a point”  
2 refers to placing a copy of the vector so that the left end of the vector is on the point.  
3 The right end of the vector then reaches a new point. “Placing a short code” or  
4 “locating a short code” refers to selecting a code position x and phase position y to  
5 generate a short code at the selected code position and with the selected phase  
6 position.

7 The following notations are used in the dither pattern diagrams shown in the  
8 figures.

- 9 • *small circle*: a selected code point, represents the chosen phase of one of the  
10 short codes.
- 11 • *small X*: a disallowed point where a code point may not be placed.
- 12 • *solid line*: a vector connecting two selected code points.
- 13 • *broken line*: a vector connecting a selected code point and a disallowed point.

14 A method for generating or designing an optimal stationary code according to  
15 the invention is shown in Fig. 10A. The method for selecting the points for the dither  
16 code is performed by a dither pattern generator, which preferably is a computer  
17 program running on a computer. However, the method for generating or designing an  
18 optimal dither code pattern also can be implemented in hardware or firmware, or by  
19 pencil and paper, as would be understood. Fig. 10B shows a table 107 constructed  
20 during the operation of the method illustrated in the flowchart of Fig. 10A. Figs. 11A  
21 through 11C are dither pattern diagrams illustrating various stages in the construction  
22 of the optimal dither code constructed according to the method shown in Fig. 10A.

23  
24 The method starts at operation 100, and in operation 101 the dither pattern  
25 generator places one short code (i.e., code 0) at phase position 0. At this time there no  
26 disallowed points. Alternatively, the initial short code can be placed at any point, and  
27 the point (0, 0) is chosen here for convenience. The selected point, in this example, is  
28 recorded in a table 107. The generator places the next short code (i.e., code 1), in  
29 operation 102, at a location based on predetermined preferences. Here, the preference  
30 is to locate subsequent short codes at points using the smallest phase jump possible.  
31 The generator checks table 107 for any disallowed points, but since there are none at

1 this time and the preference is to use the smallest phase jump, the next short code (i.e.,  
2 code 1) is placed at (1, 0), i.e., code 1 is selected to have a zero phase difference from  
3 the reference code. The generator records that code and phase as a selected point in  
4 table 107. That selected point is shown in Fig. 11A as a small circle at (1, 0).  
5 Selecting point (1, 0) also determines a first vector  $V_1$  shown as the solid line in Fig.  
6 11A, which too is recorded in table 107.

7 In operation 103 the generator determines the disallowed points based on the  
8 first vector  $V_1$ , previously disallowed points, and on the points that have already been  
9 selected, and records the newly disallowed points in table 107. In order to generate an  
10 optimal dither code, which will result in a long code that has an optimal  
11 autocorrelation, the sequence of short codes must be selected so that a vector formed  
12 between any two points in the long code is not repeated anywhere else in the code.  
13 Accordingly, in operation 103 the generator must disallow points that would form a  
14 vector corresponding to a vector that already has been formed in the long code. In this  
15 instance, there is only one vector that has been formed, namely vector  $V_1$ . The  
16 generator adds that vector to all selected code positions in the long code to locate the  
17 points to be disallowed. Here, the generator adds  $V_1$  to point (0, 0), resulting in point  
18 (1, 0), however that point is already selected so the generator ignores it. The generator  
19 also adds vector  $V_1$  to the other point in the code, point (1, 0), resulting in point (2, 0).  
20 The generator checks table 107 and determines that point (2, 0) has not been selected  
21 or previously disallowed, and accordingly disallows it by recording it in table 107 as a  
22 disallowed point. This appears on the dither pattern graph as an “X” at point (2, 0),  
23 and the vector from the selected point is shown as a broken line.

24 The process flows next to operation 104 where the next code (i.e., code 2) is  
25 selected. In this example the preference is to select a code that results in the smallest  
26 phase jump. The generator checks table 107 and finds that point (2, 0) is a disallowed  
27 point, and accordingly, code 2 can be placed at phase +1 or -1. A deterministic rule,  
28 such as selecting a positive phase jump, can be specified in the preferences and used  
29 to select the code. Alternatively, the next code can be randomly selected among the  
30 equally preferred choices. Here, +1 phase is chosen and point (2, 1) is recorded in

1 table 107. Selecting code 2 defines two new vectors,  $V_2$  and  $V_3$ , shown as solid lines  
2 in Fig. 11B, and the generator records those vectors in table 107.

3 The generator next determines, in step 105, if the dither pattern is complete. If  
4 so, the process ends at operation 106, and if not the process returns to operation 103.

5 Next, in operation 103, the generator determines disallowed points based on  
6 the newly selected points and the corresponding vectors. It does this by adding the  
7 newly determined vectors to all the selected code points, as shown by the broken lines  
8 in Fig. 11B. If those vectors reach either a selected point or a disallowed point, they  
9 are disregarded. The points where those vectors reach that have not been disregarded  
10 are points to be disallowed and are shown in Fig. 11B with an “X” and the vectors are  
11 shown with broken lines. The points those vectors reach are stored in table 107 as the  
12 newly determined disallowed code points.

13 Operation 104 is again performed using the information recorded in table 107,  
14 and here the generator selects code 3 to have a phase of 0. Hence, the generator  
15 selects code (3,0) and records that selected code in table 107. The vector to this newly  
16 selected point is shown with a solid line in Fig. 11C and is designated  $V_4$ , and is  
17 recorded in table 107. The process continues to operation 105, and since the dither  
18 pattern is not complete flow returns to operation 103.

19 Operation 103 is once again performed using the information recorded in table  
20 107. Using the newly selected code point (3, 0), vector  $V_4$  is added to each selected  
21 code point. Here, new vectors are generated and are shown with broken lines. The  
22 end points of these new vectors determine additional disallowed points that are  
23 recorded in table 107, and are shown in Fig. 11C. In operation 104 the generator  
24 determines that code 4 is allowed at phase positions -2 and +3. Since -2 is the  
25 smallest allowable phase jump, the generator selects code point (4, -2) and records it  
26 in table 107. The process will continue until in operation 105 the dither pattern is  
27 determined to be complete.

28 Optimum stationary dither codes can be generated either deterministically or  
29 randomly. For example, the generator can choose the next code point from among the  
30 two or more nearest allowable points based on a predetermined rule. Alternatively,  
31 the generator can randomly choose the next code point from among those nearest

allowable points. Also, it will be understood that other techniques for keeping track of selected code points, vectors, and disallowed points can be used, and the use of table 107 is but one such technique.

An example of an optimal stationary code generated using a computer program based on the inventive method, and the corresponding dither code pattern is represented in the graph shown in Fig. 12A. The graph in Fig. 12A represents an optimal long dither code composed of 81 short PN codes that was generated according to the invention. In Fig. 12A the solid line plots the sequence of phase positions of the optimal dither code. The dotted line plots the size of the phase jumps. In this example, in which the code generation was stopped after 80 code repetitions, the most extreme phase positions are -244 and 262.

Fig. 12B shows ten examples of optimal dither codes, each composed of 50 short PN codes, generated according to the invention. Those dither codes were generated by modifying the method to add random choices and selecting the choice that tends to return the dither pattern to a zero phase position.

Those optimal dither codes, as well as any dither code generated according to the invention, can be truncated to any desired length. The methods used to generate the codes shown in Figs. 12A and B can be modified to include random choices, or different preferences, as desired.

Having described preferred embodiments of the invention relating to generating stationary codes including optimal stationary codes, it is believed that other modifications, variations and changes will be suggested to those skilled in the art in view of the teachings set forth herein. It is therefore to be understood that all such variations, modifications and changes are believed to fall within the scope of the present invention as defined by the appended claims. Although specific terms are employed herein, they are used in their ordinary and accustomed manner only, unless expressly defined differently herein, and not for purposes of limitation.

What is Claimed is:

1           1.       A method of generating a dither code, comprising:

2           a) generating a first short code by dithering a reference code according to a  
3           dither pattern;

4           b) generating a second short code by dithering the reference code according to  
5           the dither pattern, wherein the code phases of the first and second short codes are  
6           different from each other;

7           c) repeating a) and b) a predetermined number of times; and

8           d) outputting in sequence the short codes generated in a) through c) as the  
9           dither code.

1           2.       The method according to claim 1, wherein the dither pattern changes  
2           the length of the reference code according to a predetermined pattern.

1           3.       The method according to claim 1, wherein the dither pattern changes  
2           the phase of the reference code according to a predetermined pattern.

1           4.       The method according to claim 1, wherein using the dither pattern in a)  
2           through c) results in the dither code having an optimal autocorrelation characteristic.

1           5.       The method according to claim 1, wherein the reference code is a  
2           pseudonoise code.

1           6.       The method according to claim 5, wherein the dither code is a  
2           stationary dither code.

1           7.       The method according to claim 6, wherein the dither pattern is a  
2           predetermined fixed pattern.

1           8.       The method according to claim 7, wherein the dither pattern repeats  
2           after a) and b) are repeated the predetermined number of times.

1           9. A method of generating a composite code from M instances of a  
2 reference code that has a reference phase, where M is an integer, the method  
3 comprising:

- 4           a) selecting an (N-1)th code generated from the reference code, the (N-1)th  
5 code having an (N-1)th phase position, where N is an integer less than M;  
6           b) selecting an Nth code generated from the reference code, the Nth code  
7 having an Nth phase position that is different from the (N-1)th phase, and determining  
8 a vector V between the (N-1)th code and phase and the Nth code and phase;  
9           c) adding the vector V to the (N-1)th code and codes generated prior to the (N-  
10 )th code to determine disallowed code points; and  
11           d) selecting a (N+1)th phase for a (N+1)th code from among code points other  
12 than the disallowed code points.

1           10. The method of claim 9, further comprising repeating a) through d) and  
2 incrementing N until N+1=M.

1           11. An apparatus for generating a composite code, comprising:  
2           a clock oscillator outputting a clock signal;  
3           a controller coupled to the clock oscillator, counting in response to the clock  
4 signal, and generating a control signal based on the count and indicating a dither  
5 amount; and  
6           a code generator coupled to the controller and generating a code dithered in  
7 response to the control signal, wherein the controller generates the control signal to  
8 indicate an amount of dither for the generated code so the phase of the generated code  
9 is different from the preceding code generated by the code generator.

1           12. The apparatus of claim 11, wherein the dither amount indicates a  
2 length of the code to be generated.

1           13. The apparatus of claim 11, wherein the dither amount indicates a phase  
2 rotation amount of the code to be generated.

1           14. The apparatus of claim 11, further comprising an transmission unit for  
2 transmitting the dithered code generated by the code generator.

1           15. The apparatus of claim 11, wherein the controller generates the control  
2 signal to control the code generator to produce the composite code to have an optimal  
3 autocorrelation characteristic.

1           16. The apparatus of claim 11, wherein the reference code is a pseudonoise  
2 code.

1           17. The apparatus of claim 11, wherein the controller determines the  
2 amount of dither indicated in the control signal from a dither pattern.

1           18. The apparatus of claim 17, wherein the dither pattern is fixed in length  
2 and repeats.

1           19. A transmission signal, comprising M codes each having a phase  
2 dithered with respect to a reference code, wherein the phases of the M codes are  
3 dithered according to a dither pattern.

1           20. The transmission signal of claim 19, wherein the phases of the M codes  
2 are dithered by varying the lengths of the M codes according to the dither pattern.

1           21. The transmission signal of claim 19, wherein the phases of the M codes  
2 are dithered by rotating the phase of the reference code according to the dither pattern.

1           22. The transmission signal of claim 19, wherein the M codes are dithered  
2 so that the transmission signal has an optimal autocorrelation characteristic.

1           23. The transmission signal of claim 19, wherein the dither pattern is fixed  
2 in length and repeats.

1           24. The transmission signal of claim 23, wherein the dither pattern is such  
2 that a vector difference between any two of the M codes is not repeated among the M  
3 codes.

1           25. The transmission signal of claim 24, wherein the reference code is a  
2 pseudonoise code.

## ABSTRACT OF THE DISCLOSURE

1        A generator generates a composite code from dithered copies of a reference  
2        code to form an optimal stationary dither code. The generator either dithers the length  
3        of the reference code to generate a boundary dither code composed of a series varying  
4        length short codes, or it dithers the phase of the reference code to generate rotation  
5        dither code composed of a series of fixed length short codes that vary in phase. The  
6        generator dithers the reference code according to a dither pattern. The composite code  
7        is an optimal dither code, having an optimal autocorrelation properties, by generating  
8        a dither pattern in which phase vectors for the constituent code are not repeated within  
9        the code.



**FIG. I**  
(PRIOR ART)



FIG.2  
(PRIOR ART)

FIG.3A

FIG. 3B

|               | BOUNARY<br>DITHER:             | (-)                                                     | (+)         | (-)         | (+)         | (-)         |
|---------------|--------------------------------|---------------------------------------------------------|-------------|-------------|-------------|-------------|
| <b>FIG.4A</b> |                                | 0 0 1 0 1 1 0 0 1 0 1 1 1 0 0 1 0 1 1 1 0 0 1 0 1 0 1 1 |             |             |             |             |
| <b>FIG.4B</b> | ROTATION<br>DITHER:            | 0 0 1 0 1 1 0 1 0 1 1 0 0 0 1 0 1 1 1 0 0 1 0 1 1       | (0)         | (-)         | (0)         | (+)         |
| <b>FIG.4C</b> | ALIGNED<br>REFERENCE<br>CODES: | 0 0 1 0 1 1                                             | 0 0 1 0 1 1 | 0 0 1 0 1 1 | 0 0 1 0 1 1 | 0 0 1 0 1 1 |

**FIG.5**



**FIG.6**





FIG.7

length q = L + d[c+1] - d[c]



FIG.8

**FIG.9A**

| (BOUNDARY DITHER) |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0                 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |
| 0                 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0                 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 0                 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |

**FIG.9B**

| (ROTATION DITHER) |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0                 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 0                 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 0                 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |
| 0                 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |

— MATCHING —



**FIG.10A**

**FIG.10B**

107

| CODE NO. | SELECTED POINTS | VECTORS    | DISALLOWED POINTS                                     |
|----------|-----------------|------------|-------------------------------------------------------|
| 0        | (0,0)           |            |                                                       |
| 1        | (1,0)           | $v_1$      | (2,0)                                                 |
| 2        | (2,1)           | $v_2, v_3$ | (1,1) (3,1) (3,2) (4,2)                               |
| 3        | (3,0)           | $v_4$      | (1,-1) (2,-1) (4,0)<br>(4,-1) (4,1) (5,0) (5,1) (6,0) |
| ...      | ...             | ...        | ...                                                   |



**FIG.IIA**

**FIG.IIB**



**FIG.IIC**

FIG.12A



FIG.12B

